#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string>
#include <iostream>
using namespace std;
string ss[105];
int n;
bool cmp(string a,string b){
    if(a.size()==b.size()){
        return a.compare(b)<0;
    }
    return a.size()<b.size();
}
bool check(int a,int b){
    if(ss[a].compare(ss[b])==0){
        return true;
    }
    int al=ss[a].size();
    int bl=ss[b].size();
    int i=0;
    int j=0;
    while(i<bl && j<al){
        if(ss[b][i]==ss[a][j]){
            i++;
            j++;
        }
        else{
            i-=(j-1);
            j=0;
        }
    }
    if(j==al){
        return true;
    }
    else{
        return false;
    }
}
int main(void){
    freopen("data.txt","r",stdin);
    scanf("%d",&n);
    for(int i=0;i<n;i++){
        cin >> ss[i];
    }
    sort(ss,ss+n,cmp);
    int flag=0;
    for(int i=0;i<n-1;i++){
        if(!check(i,i+1)){
            flag=1;
            printf("%d\n",i);
            break;
        }
    }
    if(flag){
        printf("NO\n");
    }
    else{
        printf("YES\n");
        for(int i=0;i<n;i++){
            cout << ss[i] << endl;
        }
    }
    return 0;
}
